Vector¶

Vector is base class of other vector like classes. It represents a series of vectors.

InĀ [1]:
from py3d import Vector
Vector()
Out[1]:
Vector([], dtype=float64)
InĀ [3]:
Vector([0, 0, 0, 0])
Out[3]:
Vector([0, 0, 0, 0])
InĀ [5]:
Vector([1, 2, -4])
Out[5]:
Vector([ 1,  2, -4])
InĀ [7]:
Vector([1, 2, 3]).tile(2)
Out[7]:
Vector([[1, 2, 3],
        [1, 2, 3]])
InĀ [9]:
import py3d
py3d.Vector([1, 2, 0, 3])
Out[9]:
Vector([1, 2, 0, 3])
InĀ [10]:
Vector([1]).tile(2)
Out[10]:
Vector([[1],
        [1]])

Get unit vector

InĀ [12]:
import py3d
V32 = py3d.Vector([
    [1, 3],
    [2, -9],
    [0.1, -3]])
V32.U
Out[12]:
Vector([[ 0.31622777,  0.9486833 ],
        [ 0.21693046, -0.97618706],
        [ 0.03331483, -0.99944491]])

Get length of vectors

InĀ [13]:
V32.L
Out[13]:
array([3.16227766, 9.21954446, 3.0016662 ])
InĀ [15]:
from numpy import allclose
assert allclose(V32.U.L, [[1], [1], [1]])

Get homogeneous vector

InĀ [16]:
V32.H
Out[16]:
Vector3([[ 1. ,  3. ,  1. ],
         [ 2. , -9. ,  1. ],
         [ 0.1, -3. ,  1. ]])

Get a series of random vectors

InĀ [18]:
import py3d
py3d.Vector.rand(2, 3, 4)
Out[18]:
Vector([[[0.76430443, 0.54231843, 0.33844462, 0.48907184],
         [0.54590579, 0.31145266, 0.4912591 , 0.31401749],
         [0.53637556, 0.35239776, 0.46103096, 0.14384169]],

        [[0.02988301, 0.13582655, 0.69489263, 0.91050638],
         [0.47190468, 0.66291903, 0.15420923, 0.68694434],
         [0.52017341, 0.99113248, 0.11066013, 0.02418476]]])
InĀ [20]:
import py3d
py3d.Vector([[0, 0], [1, 2], [3, 4]]).diff()
Out[20]:
Vector([[1, 2],
        [2, 2]])

Write csv file

InĀ [22]:
import py3d
py3d.Vector([[1,2,3],[4,5,6]]).to_csv("tmp.csv")

Read csv file

InĀ [23]:
import py3d
py3d.read_csv("tmp.csv")
Out[23]:
Vector([[1., 2., 3.],
        [4., 5., 6.]])

Read pcd file

InĀ [24]:
import py3d

py3d.read_pcd("ascii.pcd").xyz.as_point()
Out[24]:
InĀ [25]:
import py3d
pcd = py3d.read_pcd("binary.pcd")
print("min", pcd.min())
print("max", pcd.max())
pcd.xyz.as_point().paint(py3d.Color.map(pcd.z))
min [-1.09082863e+02 -4.56674919e+01 -4.33038330e+00  2.50000000e+01  1.22393358e+09]
max [9.74602280e+01 8.35153122e+01 4.22846746e+00 2.55000000e+02 1.22393358e+09]
Out[25]:

Write npy file

InĀ [26]:
import py3d
py3d.Vector([1,2,3]).to_npy("tmp.npy")

Read npy file

InĀ [27]:
import py3d
py3d.read_npy("tmp.npy")
Out[27]:
Vector([1, 2, 3])

Read a real lidar point cloud from a npy file

InĀ [28]:
import py3d
py3d.read_npy("lidar.npy").xyz.as_point()
Out[28]:

Read a depth map from a npy file

InĀ [29]:
import py3d
py3d.read_npy("depth.npy").z.as_image(sample_rate=1)
Out[29]:

Read ply file

InĀ [30]:
import py3d
vertices, mesh = py3d.read_ply("cube.ply")
print(vertices)
mesh
[[0. 0. 0.]
 [0. 0. 1.]
 [0. 1. 1.]
 [0. 1. 0.]
 [1. 0. 0.]
 [1. 0. 1.]
 [1. 1. 1.]
 [1. 1. 0.]]
Out[30]: